• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            asm, c, c++ are my all
            -- Core In Computer
            posts - 139,  comments - 123,  trackbacks - 0

            /********************************************\
            |????歡迎轉載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!???? |
            \********************************************/


            非“偽”隨機數的生成

            作者: Jerry Cat
            時間: 2006/05/16
            鏈接:?
            http://www.shnenglu.com/jerysun0818/archive/2006/05/16/7232.html

            問題的來由 - "隨機取m個數(在1到n的范圍之內),(m <= n),要求m個數沒有重復。有沒有
            什么好的算法,時間復雜度和空間復雜度都很好"

            ----------------------------------------------------------------
            方案一:
            取隨機數可以用C++標準的rand,至于M個不重復,你可以用std::set來解決,把取道的隨機數
            插入到set里面,set的size() == m就可以了, 具體可以這樣:

            #include <set>
            #include <stdlib.h>

            int main()
            {
            ?? std::set<int> s;
            ?? while(1)
            ?? {
            ????? int r = rand() % n;
            ????? s.insert(r);
            ????? if(s.size() == m)
            ????? {
            ???????? break;
            ????? }
            ?? }
            }

            ?由于set底層實現是紅黑樹,插入復雜度是對數級的^_^

            ----------------------------------------------------------------
            方案二:
            #include <iostream>
            #include <cstdlib>????? //用于rand()和srand()函數
            #include <ctime>??????? //設置不同的隨機數

            using namespace std;

            int main (){
            ??? srand( time( 0 ) );??? //調用不重復的隨機數函數
            ??? unsigned i;
            ??? for ( int n = 0; n++ < 10; )
            ??? {
            ??????? i = rand() ;??????? //對i 賦系統的隨機數
            ??????? cout << " The NO." << n << "is : " << i << endl;
            ??? }

            ??? return 0;
            }

            1. C++標準函數庫提供一隨機數生成器rand,返回0-RAND_MAX之間均勻分布的偽隨機整數。 RAND_MAX
            ?? 必須至少為32767。rand()函數不接受參數,默認以1為種子(即起始值)。

            ?? 隨機數生成器總是以相同的種子開始,所以形成的偽隨機數列也相同。失去了隨機意義。

            2. C++中另一函數srand(),可以指定不同的數(無符號整數變元)為種子。但是如果種子相同,偽
            ?? 隨機數列也相同。--一個辦法是讓用戶輸入種子,但是仍然不理想。

            3. 比較理想的是用變化的數,比如時間來作為隨機數生成器的種子。
            ?? 在 頭文件ctime中時間庫包含time函數,它可以返回一個表示時間、日期、月和年的數值使用如
            ?? 下調用可將該值設為rand的種子
            ?? srand(static_cast<unsigned>(time(static_cast<time_t*>(NULL))));

            4. 但, srand()并不是說使隨機數都不一樣,它只是使取隨機數的種子隨著時間而改變:)
            ?? So, 還是方案一好!

            posted on 2006-05-16 00:17 Jerry Cat 閱讀(2539) 評論(7)  編輯 收藏 引用

            FeedBack:
            # re: 非“偽”隨機數的生成
            2006-05-16 21:38 | Tauruser
            方案一中 int r = rand() % n;
            n是什么來的,沒有見你定義的?  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2006-05-29 01:57 | xfh
            n就是1-n中的n, 具體數值隨要求而定  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2007-01-19 14:54 | sjd163
            方案一,過程可以重復出現,怎么會不是偽隨機數呢?
            看不到不偽的隨機數在哪里?  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2007-01-19 16:46 | Dain
            啥叫偽  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2008-08-05 10:43 | xy
            方案一不具有操作性,太消耗時間  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2008-12-18 08:43 | 得到
            被騙點擊了  回復  更多評論
              
            # re: 非“偽”隨機數的生成
            2009-05-29 23:24 | pop
            方案一真的可行?命題要求m個數沒有重復,%n之后的m個數中極有可能有重復  回復  更多評論
              

            <2006年5月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久天天躁狠狠躁夜夜av浪潮| www久久久天天com| 久久天天躁狠狠躁夜夜avapp| 精品多毛少妇人妻AV免费久久| 久久亚洲精品国产精品| 欧美亚洲另类久久综合| 亚洲国产精品综合久久一线| 人妻无码久久一区二区三区免费| 韩国免费A级毛片久久| 久久综合一区二区无码| 久久综合给合久久狠狠狠97色 | 国产精品永久久久久久久久久| 欧美精品丝袜久久久中文字幕 | 久久人人爽人人爽人人片AV东京热| 一本一道久久综合狠狠老| 99久久精品国产一区二区蜜芽| 久久香综合精品久久伊人| 国产成人无码精品久久久免费| 亚洲精品tv久久久久久久久| 久久亚洲精品无码播放| 久久久精品一区二区三区| 性高湖久久久久久久久| 久久久久久国产a免费观看黄色大片 | 国产精品美女久久久久网| 欧美一区二区久久精品| 国产精品亚洲综合专区片高清久久久| 亚洲人成精品久久久久| 一级女性全黄久久生活片免费| 97精品国产97久久久久久免费| 99久久超碰中文字幕伊人| 久久丫精品国产亚洲av不卡 | 亚洲精品午夜国产VA久久成人| 久久久久亚洲av毛片大| 国产福利电影一区二区三区,免费久久久久久久精 | av无码久久久久久不卡网站| 午夜天堂精品久久久久| 少妇久久久久久被弄高潮| 亚洲国产另类久久久精品| 久久久久久久久波多野高潮| 久久人人爽人人爽人人片av麻烦| 久久久久久国产精品无码下载|